2017-08-23 17:55:27 Iven_ma 阅读数 5617

最近做项目实现新的需求,初始状态导航栏透明,随着滑动的过程中,改变导航栏的透明度,逐渐颜色加深。

网上找到了两种解决方案。

第一种,通过研究导航栏的结构图,找出影响背景颜色的控件,对其进行控制改变。

NavigationBar背后有一张类型_UINavigationBarBackground(UIImageView的子类)的视图,所以我们设置背景的时候就是设置的_UINavigationBarBackground的image。然后通过改变这个控件的透明度来实现。

该方法是网上的一个大神,实现的比较好,感兴趣的小伙伴可以参考一下,文章链接
http://www.cocoachina.com/ios/20160606/16608.html
不过,我在使用大神封装的类库,最终并没有解决问题,实现不了我想要的功能,所以继续在网上探索其它方法。

第二种,实现了我想要的效果,在这里推荐大家优先尝试下面的解决方案。

在导航栏上加一个view,自己控制view的背景颜色,初始的时候不需要设置背景颜色,然后在滑动过程中,通过滑动的数据改变透明度,直接上代码。

//懒加载实现背景View
- (UIView*)bgView {
    if (_bgView == nil) {
        _bgView = [[UIImageView alloc]initWithFrame:CGRectMake(0, 0, self.navigationController.navigationBar.frame.size.width, self.navigationController.navigationBar.frame.size.height + 20)];
        [self.navigationController.view insertSubview:_bgView belowSubview:self.navigationController.navigationBar];

    }
    return _bgView;
}

然后在代理方法中,改变alpha的值。这里由于主页页面较长通过滑动600的距离后达到透明度的值改为1。

- (void)scrollViewDidScroll:(UIScrollView *)scrollView {
    CGFloat alpha = scrollView.contentOffset.y/600;
    if (alpha > 1) {
        alpha = 1;
    }
    if (scrollView == _backgroundScrollV) {  
        [self bgView].backgroundColor = [UIColor colorWithRed:242.0/255 green:100.0/255 blue:50.0/255 alpha:alpha];
    }
}

初始页面

这里写图片描述

这里写图片描述

2016-09-07 14:03:10 liu_bin_home 阅读数 4345

1.设置导航栏颜色

self.navigationController.navigationBar.barTintColor =[UIColor redColor];


2.在tableview滑动的协议中,设置导航栏的透明度,类似QQ空间的

/**

 * tableview滑动的时候出发的协议 继承UIScrollview 可以直接使用

 */

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

    

    if ((-64<scrollView.contentOffset.y)&&(scrollView.contentOffset.y<0)){

        NSLog(@"scrollview did scroll %@ %f",NSStringFromCGPoint(scrollView.contentOffset), 1-(fabsf(scrollView.contentOffset.y)/64));

        [[self.navigationController.navigationBar subviewsobjectAtIndex:0].alpha=1-(fabsf(scrollView.contentOffset.y)/64);

    }

}

2017-12-13 09:40:48 weixin_34348111 阅读数 44

最近公司项目,需要在首页实现一个效果,随着屏幕的滚动,导航栏背景色从没有到完全显示也就是透明度从0-1的过程.效果如下

实现方法 1.随着屏幕的滚动,改变导航栏的alpha,但是这样有一个不好的现象,就是导航栏leftItem,rightItem等也会跟着改变,这个效果不是我需要的,我需要的是只改变背景色的alpha 2.我在导航栏上添加了一个view,让view随着屏幕的滚动实现效果,这个时候,添加的view最好在最底层,这样才不会让你添加的view遮盖住其他控件.部分代码如下
在viewDidLoad中添加如下代码 [self.navigationController.navigationBar insertSubview:self.aplhaView atIndex:0]; 但是这样会有一个问题,在这个页面pusg或者modal后的页面中,刚才添加的view可能会布局在导航栏的最顶部或者其他的位置,这是因为,在push或者modal的时候,导航栏会重新调整布局,这个时候,我们就要改变刚刚ViewDidLoad中的代码

[[self.navigationController.navigationBar.subviews firstObject] insertSubview:self.aplhaView atIndex:0];
复制代码

Demo 结束语: 文章可能会存在错误,欢迎指正!

2017-03-28 14:55:29 rainbow201314 阅读数 187

文章转自:http://www.cocoachina.com/ios/20160606/16608.html

首先我们来看下效果

1465185529377975.gif

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

1465185605545250.png

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的结构图

1465185630866559.png

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

运行效果如图:

1465185651352585.png

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

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

  • 设置渐变图片

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

  • 运行时动态绑定

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

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

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

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

1
barImageView = self.navigationController.navigationBar.subviews.firstObject

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

3.其实已经可以了

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

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

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

1488504-d4f949950141899b.gif

没有更多推荐了,返回首页