当前位置: 首页 > 编程笔记 >

iOS实现scrollview上拉显示Navbar下拉隐藏功能详解

张啸
2023-03-14
本文向大家介绍iOS实现scrollview上拉显示Navbar下拉隐藏功能详解,包括了iOS实现scrollview上拉显示Navbar下拉隐藏功能详解的使用技巧和注意事项,需要的朋友参考一下

本文主要介绍的是关于iOS中scrollview上拉显示Navbar下拉隐藏的相关内容,分享出来供大家参考学习,下面来看看详细的介绍:

动画效果:


关于下拉隐藏Nabbar,上拉显示,有三种方式:推崇第一种,但是做的还是没简书、知乎那样流畅,第一种是对navbar做了平移,第二种,第三种都是隐藏。。

方法如下:

第一种,和第二种处理时机一样,但是效果更好,并没有处理Navbar 的隐藏。

-(void)scrollViewWillBeginDragging:(UIScrollView *)scrollView{
 oldY = scrollView.contentOffset.y;
}
-(void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate{
  if (scrollView.contentOffset.y > oldY) {


   [UIView animateWithDuration:0.3 animations:^{
    self.navigationController.navigationBar.transform =
    CGAffineTransformMakeTranslation(0, -64);

   }];

   ;

  }else{
   [UIView animateWithDuration:0.3 animations:^{
    self.navigationController.navigationBar.transform =
    CGAffineTransformIdentity;

   }];
  }
}
-(void)viewWillDisappear:(BOOL)animated{
 self.navigationController.navigationBar.transform = CGAffineTransformIdentity;

}

第二种:在开始拖拽的时候保存偏移量,结束拖拽的时候比较当前偏移量,判断是否隐藏Navbar。

-(void)scrollViewWillBeginDragging:(UIScrollView *)scrollView{
 oldY = scrollView.contentOffset.y;
}
-(void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate{
  if (scrollView.contentOffset.y > oldY) {

   [CATransaction begin];
   [CATransaction setAnimationDuration:1.0];
   [CATransaction setAnimationTimingFunction:[CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionLinear]];
   //set the position
   [self.navigationController setNavigationBarHidden:YES animated:YES];
   [CATransaction commit];
   ;

  }else{
   [CATransaction begin];
   [CATransaction setAnimationDuration:1.0];
   [CATransaction setAnimationTimingFunction:[CAMediaTimingFunction functionWithName:kCAMediaTimingFunctionLinear]];
    [self.navigationController setNavigationBarHidden:NO animated:YES];
    [CATransaction commit];

  }
}

第三种: 是根据拖拽的velocity进行判断,很霸道但是效果不如第一种,,隐藏的时机不对你可以做个比较;

-(void)scrollViewWillEndDragging:(UIScrollView *)scrollView withVelocity:(CGPoint)velocity targetContentOffset:(inout CGPoint *)targetContentOffset{

 if(velocity.y>0)

 {

  [self.navigationController setNavigationBarHidden:YES animated:YES];

 }

 else

 {

  [self.navigationController setNavigationBarHidden:NO animated:YES];

 }

}
最后选择合适的时候恢复Navbar 的状态,建议放在viewWillDisappear里,否则在进入下一个页面里很突兀。
-(void)viewWillDisappear:(BOOL)animated{
 [self.navigationController setNavigationBarHidden:NO animated:YES];
}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家小牛知识库的支持。

 类似资料:
  • 本文向大家介绍jQuery实现的点击显示隐藏下拉菜单功能完整示例,包括了jQuery实现的点击显示隐藏下拉菜单功能完整示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了jQuery实现的点击显示隐藏下拉菜单功能。分享给大家供大家参考,具体如下: PS:感兴趣的朋友可以使用如下在线工具测试上述代码: 在线HTML/CSS/JavaScript前端代码调试运行工具: http://tools

  • 本文向大家介绍iOS 三级下拉菜单功能实现,包括了iOS 三级下拉菜单功能实现的使用技巧和注意事项,需要的朋友参考一下 前言 App 常用控件 -- 多级下拉菜单, 如团购类, 房屋类, 对数据进行筛选. 有一级, 二级, 三级, 再多就不会以这种样式,呈现给用户了. 作者就简单聊一下 多级下拉菜单 一 目标 默认显示一个 TableView, 点击数据后, 添加第二个TableView, 并实现

  • 本文向大家介绍vue实现密码显示隐藏切换功能,包括了vue实现密码显示隐藏切换功能的使用技巧和注意事项,需要的朋友参考一下 先给大家分享效果图: 具体实现代码如下所示: html: script: 注:带小眼睛的睁开闭合。 总结 以上所述是小编给大家介绍的vue实现密码显示隐藏切换功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对呐喊教程网站的支持!

  • 本文向大家介绍微信小程序实现页面下拉刷新和上拉加载功能详解,包括了微信小程序实现页面下拉刷新和上拉加载功能详解的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了微信小程序实现页面下拉刷新和上拉加载功能。分享给大家供大家参考,具体如下: web手机端或App中经常会有下拉刷新,上拉加载这些功能。 微信小程序中如何实现下拉刷新,上拉加载的功能。 实现思路: 1.监听界面的下拉刷新事件和上拉加载事

  • 本文向大家介绍Android ListView实现上拉加载更多和下拉刷新功能,包括了Android ListView实现上拉加载更多和下拉刷新功能的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家介绍了Android ListView下拉刷新功能的实现方法和功能,供大家参考,具体内容如下 1、ListView优化方式 界面缓存:ViewHolder+convertView 分页加载:上拉刷新

  • 本文向大家介绍JS实现“隐藏与显示”功能(多种方法),包括了JS实现“隐藏与显示”功能(多种方法)的使用技巧和注意事项,需要的朋友参考一下 下面我将效果图展示出来: 1,通过按钮实现隐藏与显示: 这个是通过按钮点击实现的隐藏与显示,具体代码如下: 其中,主要能够实现这个功能的是js代码, 通过getElementById()这个方法找到对应元素,进而控制它的style,以此来做对应的功能。这是一个