iOS UIScrollView上滑隐藏UINavigationBar

欢迎大家关注我的公众号,我会定期分享一些我在项目中遇到问题的解决办法和一些iOS实用的技巧,现阶段主要是整理出一些基础的知识记录下来

文章也会同步更新到我的博客:
ppsheep.com

我们经常看到一些阅读类的应用,上滑UIScrollView的时候 UINavigationBar就隐藏了 虽然Apple给我们提供了隐藏NavigationBar的方法,但是有一个弊端 就是navigationbar不能随着UIScrollView的滑动速度来隐藏,并且设置bar逐渐隐藏,今天我们就来实现这样一个效果

首先看一下效果

1

首先分析一下,随着滑动隐藏NavigationBar,肯定是在UIScrollView的delegate方法scrollViewDidScroll:做操作

UINavigationBar Category

在UINavigationBar中


@interface UINavigationBar (PPSNavigationBar)
/**
 设置scrollview的透明度 随着滑动  透明度改变

 @param alpha 透明度
 */
- (void)pps_setScrollViewAlpha:(CGFloat)alpha;


/**
 设置Bar偏移

 @param translationY 偏移量
 */
- (void)pps_setTranslationY:(CGFloat)translationY;

@end复制代码

.m

@implementation UINavigationBar (PPSNavigationBar)

-(void)pps_setTranslationY:(CGFloat)translationY{
    self.transform = CGAffineTransformMakeTranslation(0, translationY);
}

-(void)pps_setScrollViewAlpha:(CGFloat)alpha{
    [[self valueForKey:@"_leftViews"] enumerateObjectsUsingBlock:^(UIView *view, NSUInteger i, BOOL *stop) {
        view.alpha = alpha;
    }];

    [[self valueForKey:@"_rightViews"] enumerateObjectsUsingBlock:^(UIView *view, NSUInteger i, BOOL *stop) {
        view.alpha = alpha;
    }];

    UIView *titleView = [self valueForKey:@"_titleView"];
    titleView.alpha = alpha;

    [[self subviews] enumerateObjectsUsingBlock:^(UIView *obj, NSUInteger idx, BOOL *stop) {
        if ([obj isKindOfClass:NSClassFromString(@"UINavigationItemView")]) {
            obj.alpha = alpha;
            *stop = YES;
        }
    }];
}

@end复制代码

实现起来很简单

在NavigationBar中

  • _leftViews
  • _rightViews
  • _titleView
  • UINavigationItemView

这几个属性都是UINavigationBar的属性,如果不知道这几个属性 是可以通过runtime得到这几个属性的

具体的实现方法参考我的另一篇文章:

ppsheep.com/2016/10/31/…

通过几个属性名我们就能知道 代表什么

然后在我们的viewcontroller中

-(void)scrollViewDidScroll:(UIScrollView *)scrollView{
    //这里加上64是为了得到准确的scrollview的偏移量  当然你也可以在下面的判断中计算
    CGFloat offsetY = scrollView.contentOffset.y+64;
    if (offsetY > 0) {
        if (offsetY >= 44) {
            [self setNavigationBarTransformProgress:1];
        } else {
            [self setNavigationBarTransformProgress:(offsetY/44)];
        }
    } else {
        [self setNavigationBarTransformProgress:0];
        self.navigationController.navigationBar.backIndicatorImage = [UIImage new];
    }
}

- (void)setNavigationBarTransformProgress:(CGFloat)progress
{
    [self.navigationController.navigationBar pps_setTranslationY:(-44 * progress)];
    [self.navigationController.navigationBar pps_setScrollViewAlpha:(1-progress)];
}复制代码

实现起来 还是很简单的

源工程:

github.com/yangqian111…

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值