首先我们来看下效果
一开始当我们什么只设置了一张图片作为它的头部视图的时候,它是这样的
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.还得让它不仅仅是透明
这,怎么整?我们有几种方案
设置渐变图片
根据上面设置为透明的方法,我们最直接能想到的还是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之间变化:
- (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。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# iOS导航栏透明渐变
# iOS导航透明渐变
# iOS透明渐变
# iOS 封装导航栏及返回
# 获取控件所在控制器的实例
# 详解iOS11关于导航栏问题
# 两种iOS隐藏导航栏的正确方法
# iOS App开发中导航栏的创建及基本属性设置教程
# iOS实现导航栏透明示例代码
# 简单好用的iOS导航栏封装.runtime属性控制实例代码
# 我们可以
# 绑定
# 你可以
# 它是
# 设置为
# 图中
# 那根
# 的是
# 都是
# 状态栏
# 细线
# 几个
# 如果你
# 我在
# 偏移量
# 就在
# 是有
# 第一个
# 你就
# 他是
相关文章:
如何处理“XML格式不正确”错误 常见XML well-formed问题解决方法
定制建站平台哪家好?企业官网搭建与快速建站方案推荐
如何彻底卸载建站之星软件?
Bpmn 2.0的XML文件怎么画流程图
高端建站三要素:定制模板、企业官网与响应式设计优化
如何用腾讯建站主机快速创建免费网站?
长沙企业网站制作哪家好,长沙水业集团官方网站?
代刷网站制作软件,别人代刷火车票靠谱吗?
c++怎么用jemalloc c++替换默认内存分配器【性能】
如何配置支付宝与微信支付功能?
建站主机是否属于云主机类型?
如何快速搭建自助建站会员专属系统?
股票网站制作软件,网上股票怎么开户?
制作网站哪家好,cc、.co、.cm哪个域名更适合做网站?
合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?
新网站制作渠道有哪些,跪求一个无线渠道比较强的小说网站,我要发表小说?
建站之星如何实现网站加密操作?
如何高效完成独享虚拟主机建站?
如何在IIS中新建站点并配置端口与IP地址?
如何在万网自助建站中设置域名及备案?
如何快速选择适合个人网站的云服务器配置?
Android自定义listview布局实现上拉加载下拉刷新功能
广东企业建站网站优化与SEO营销核心策略指南
武汉网站如何制作,黄黄高铁武穴北站途经哪些村庄?
如何在阿里云部署织梦网站?
c++23 std::expected怎么用 c++优雅处理函数错误返回【详解】
建设网站制作价格,怎样建立自己的公司网站?
建站之星如何防范黑客攻击与数据泄露?
英语简历制作免费网站推荐,如何将简历翻译成英文?
实现点击下箭头变上箭头来回切换的两种方法【推荐】
,石家庄四十八中学官网?
音乐网站服务器如何优化API响应速度?
建站之星如何配置系统实现高效建站?
网站设计制作书签怎么做,怎样将网页添加到书签/主页书签/桌面?
如何快速查询网站的真实建站时间?
如何零基础在云服务器搭建WordPress站点?
小型网站制作HTML,*游戏网站怎么搭建?
如何在云服务器上快速搭建个人网站?
建站一年半SEO优化实战指南:核心词挖掘与长尾流量提升策略
Avalonia如何实现跨窗口通信 Avalonia窗口间数据传递
建站之星Pro快速搭建教程:模板选择与功能配置指南
南阳网站制作公司推荐,小学电子版试卷去哪里找资源好?
如何彻底删除建站之星生成的Banner?
如何选择PHP开源工具快速搭建网站?
建站之星如何助力网站排名飙升?揭秘高效技巧
建站VPS选购需注意哪些关键参数?
,想在网上投简历,哪几个网站比较好?
电商平台网站制作流程,电商网站如何制作?
专业网站设计制作公司,如何制作一个企业网站,建设网站的基本步骤有哪些?
建站之星后台管理:高效配置与模板优化提升用户体验
*请认真填写需求信息,我们会在24小时内与您取得联系。