上滑隐藏NvaigtionBar,下拉显示

前言

今天和产品沟通,要仿照一个APP,发现这个APP上滑时隐藏navigationBar,虽然也是隐藏但是效果和其他完全不一样,因为以前没见过也没做过,所以试着去实现一下,Google了一下,发现思路主要还是从KVO来下手。

原APP的效果

2016-08-11 16_23_42.gif

实现过程

  • 主要是给view中的滚动视图添加一个KVO来监视它的滑动,再根据它的offset来做一下操作,下面是代码
 [myTableView addObserver:self forKeyPath:@"contentOffset" options:NSKeyValueObservingOptionOld|NSKeyValueObservingOptionNew context:nil];
  • 获取tableView的contentOffset之后再根据具体需求来实现逻辑判断
- (void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object change:(NSDictionary<NSString *,id> *)change context:(void *)context {
    if ([object isEqual:myTableView] && [keyPath isEqualToString:@"contentOffset"]) {
        //获取新值旧值
        CGFloat newY = [change[@"new"] CGPointValue].y;
        CGFloat oldY = [change[@"old"] CGPointValue].y;
        float i = newY - oldY;//下拉是新值小于旧值的,所以i<0 是下拉 i>0 是上滑
         NSLog(@"%f",myTableView.contentOffset.y);
        if (myTableView.contentOffset.y > -64 && myTableView.contentOffset.y <= 24) {//边界条件,此处不精确
            if (i <= 0 && _isHide == NO && self.navigationController.navigationBar.frame.origin.y == 20){
                //下拉+bar 已经显示的状态,不再移动
                return;
            }
            _isHide = NO;
            //设置navigationbar 的frame 使他根据tableView来滑动
            self.navigationController.navigationBar.frame = CGRectMake(0, -44 - myTableView.contentOffset.y, self.view.bounds.size.width, 44);
            //控制透明度
            self.navigationController.navigationBar.alpha = -myTableView.contentOffset.y/64;
        }else if (myTableView.contentOffset.y > 24) {
            if (i > 10) {//更改数值大小可以控制触发 navigation bar 的滑动速度
                _isHide = YES;
            }else if(i < -10) {
                _isHide = NO;
            }
        }
        [self.navigationController setNavigationBarHidden:_isHide animated:YES];
    }
}

完成效果图

2016-08-11 15_55_00.gif

总结

  • 实现起来确实没有什么难度,主要是因为以前没有做过,写这个主要是给大家看一下我的实现过程与思路,希望可以帮到大家。

  • 我把源码上传到GitHub了,需要的可以看一下。

  • 我的个人网站

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 176,752评论 25 709
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 14,770评论 4 61
  • 深夜提笔难写意,字字句句我和你。 月下高歌来一曲,风花雪月关乎你。
    瞿静阅读 1,373评论 0 2
  • 大学,到底是一种什么样的生活状态?我忽然这样问自己。我不明白,我现在做的事情有什么意义,或者说,我看不透自己的心,...
    佩玹轻叩阅读 2,571评论 0 3
  • 前不久有缘认识了一位“儒商”,之所以称为“儒商”,是因为这位H先生经营着一家工厂,而且经营的比较精致。但是H先...
    悠云小筑阅读 2,586评论 0 2

友情链接更多精彩内容