IOS实现上滑隐藏NvaigtionBar而下拉则显示效果

 更新时间:2016年09月01日 14:42:37   投稿:daisy  
这篇文章给大家介绍了如何实现APP上滑时隐藏navigationBar而下拉则又会显示,虽然也是隐藏但是效果和其他完全不一样,因为以前没做过所以试着去实现一下,现在分享给大家,有需要的可以参考借鉴。

先看看原APP的效果

实现过程

主要是给view中的滚动视图添加一个KVO来监视它的滑动,再根据它的offset来做一下操作,下面是代码

[myTableView addObserver:self forKeyPath:@"contentOffset" options:NSKeyValueObservingOptionOld|NSKeyValueObservingOptionNew context:nil];

获取tableViewcontentOffset 之后再根据具体需求来实现逻辑判断

-(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];
 }
}

完成效果图

总结

其实这个效果实现起来确实没有什么难度,写这个主要是给大家看一下我的实现过程与思路,希望可以帮到大家。如果有疑问可以留言交流,谢谢大家对脚本之家的支持。

相关文章

  • 分享一些iOS开发实用的小技巧

    分享一些iOS开发实用的小技巧

    这篇文章主要给大家分享了一些iOS开发实用的小技巧,这些小技巧在大家开发iOS的时候还是相当实用,有需要的朋友们下面来一起看看吧。
    2016-09-09
  • iOS如何为导航栏添加播放动画

    iOS如何为导航栏添加播放动画

    这篇文章主要为大家详细介绍了iOS如何为导航栏添加播放动画的方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-10-10
  • iOS中正则表达式的运用示例代码

    iOS中正则表达式的运用示例代码

    正则表达式(广为所知的“regex”)是一个字符串或一个字符序列来说明一种模式,把它作为一个搜索字符串-非常强大!下面这篇文章主要给大家介绍了关于iOS中正则表达式运用的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下。
    2017-09-09
  • iOS应用内实现跳转到手机淘宝天猫的方法

    iOS应用内实现跳转到手机淘宝天猫的方法

    这篇文章主要给大家介绍了关于iOS应用内如何实现跳转到手机淘宝天猫的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧。
    2017-12-12
  • objective-c中生成随机数的方法

    objective-c中生成随机数的方法

    这篇文章主要介绍了objective-c中生成随机数的方法,比较实用的功能,需要的朋友可以参考下
    2014-08-08
  • iOS利用MJRefresh实现自定义刷新动画效果

    iOS利用MJRefresh实现自定义刷新动画效果

    本文主要介绍iOS 利用MJRefresh实现自定义动画的上拉刷新下拉加载效果,要想实现此功能,首先得有一套load的图片数组。接下来通过本文给大家详解介绍实现过程
    2017-02-02
  • iOS通过多种方式创建控制器

    iOS通过多种方式创建控制器

    这篇文章主要为大家详细介绍了iOS通过多种方式创建控制器的相关方法,感兴趣的小伙伴们可以参考一下
    2016-04-04
  • iOS中CPU线程调试的高级技巧分享

    iOS中CPU线程调试的高级技巧分享

    这篇文章主要给大家介绍了关于iOS中CPU线程调试的高级技巧,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-11-11
  • iOS开发实现搜索框(UISearchController)

    iOS开发实现搜索框(UISearchController)

    这篇文章主要为大家详细介绍了iOS开发实现搜索框,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-08-08
  • 详解IOS中Tool Bar切换视图方法

    详解IOS中Tool Bar切换视图方法

    这篇文章主要介绍了详解IOS中Tool Bar切换视图方法以及实例代码分析,需要的朋友学习一下吧。
    2017-12-12

最新评论